File manager - Edit - /home/autoph/public_html/projects/app/Http/Controllers/API/v1/DepartmentController.php
Back
<?php namespace App\Http\Controllers\API\v1; use App\Http\Controllers\Controller; use Illuminate\Http\Request; use Illuminate\Support\Facades\Validator; use Illuminate\Http\Response; use App\Models\Department; use Illuminate\Support\Facades\DB; use Illuminate\Validation\Rule; use Throwable; class DepartmentController extends Controller { /** * Display a listing of the resource. */ public function index(Request $request) { $keyword = $request->input('keyword', ''); $perPage = $request->input('per_page',PHP_INT_MAX); $sortBy = $request->input('sortBy', ''); $sortType = $request->input('sortType', ''); $data = Department::with('division')->where(function ($query) use ($keyword) { $keyword = str_replace(" ","%",$keyword); $query->where('name','like','%'. $keyword . '%') ->orWhere('code', 'like', '%' . $keyword . '%'); }); if(!empty($sortBy) && !empty($sortType)){ $data = $data->orderby($sortBy, $sortType); } $data = $data->paginate($perPage); return response()->json($data); } /** * Store a newly created resource in storage. */ public function store(Request $request) { $validator = Validator::make($request->all(), [ 'division_id' => 'required', 'name' => 'required|min:2|unique:departments,name' ]); /** If validation fails return with error message */ if ($validator->fails()) { $errors = $validator->errors(); $first = $errors->getMessages(); return response()->json([ 'status' => false, 'message' => (reset($first))[0], 'errors' => $errors ], Response::HTTP_UNPROCESSABLE_ENTITY); } DB::connection()->beginTransaction(); try { $data = Department::create($request->all()); DB::connection()->commit(); return response()->json([ 'message' => 'Record Successfully added!', 'status' => 'success', ], 201); } catch (Throwable $e) { DB::connection()->rollback(); return response()->json([ 'status' => false, 'message' => 'Unable to process request. Please try again.', 'data' => $e->getMessage() ]); } } /** * Display the specified resource. */ public function show(string $id) { // } /** * Update the specified resource in storage. */ public function update(Request $request, string $id) { $data = Department::where('id',$id)->first(); if(!$data){ return response()->json(['messages'=> "No data found."],404); } $validator = Validator::make($request->all(), [ 'division_id' => [ 'required', ], 'name' => [ 'required', 'min:2', Rule::unique('departments')->ignore($id)->whereNull('deleted_at') ], ] ); /** If validation fails return with error message */ if ($validator->fails()) { $errors = $validator->errors(); $first = $errors->getMessages(); return response()->json([ 'status' => false, 'message' => (reset($first))[0], 'errors' => $errors ], Response::HTTP_UNPROCESSABLE_ENTITY); } DB::connection()->beginTransaction(); try{ $data->fill($request->all()); $data->save(); $data->touch(); DB::connection()->commit(); return response()->json([ 'messages' => "Record successfully updated!", "status" => "success", "data" => $data ],201); }catch(Throwable $e){ DB::connection()->rollback(); return response()->json([ 'messages' => "Unable to process request. Please try again.", 'status' => false, 'data' => $data ]); } } /** * Remove the specified resource from storage. */ public function destroy(string $id) { $data = Department::find($id); if(!$data) { return response()->json(['message' => "Record not found!",204]); } DB::connection()->beginTransaction(); $data->delete(); DB::connection()->commit(); return response()->json(['message' => "Record successfully deleted!"],200); } }
| ver. 1.4 |
.
| PHP 8.1.32 | Generation time: 0 |
proxy
|
phpinfo
|
Settings